package com.vooda.dao;

import com.vooda.entity.UserTicket;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;

import java.util.List;

/**
 * @author KennyDavid
 */
public interface UserTicketDao extends JpaRepository<UserTicket, Long>, JpaSpecificationExecutor<UserTicket> {

    /**
     * 查询我的优惠券
     *
     * @param userId 用户id
     * @param status 状态
     * @return list
     */
    List<UserTicket> findAllByUserIdAndStatusOrderByCreateTimeDesc(Long userId, Integer status);

    /**
     * 查询是否领过优惠券
     *
     * @param userId   用户id
     * @param ticketId 优惠券id
     * @return userTicket
     */
    UserTicket findByUserIdAndTicketId(Long userId, Long ticketId);

    /**
     * 查询是否领过优惠券且未使用
     *
     * @param userId   用户id
     * @param ticketId 优惠券id
     * @param status   优惠券状态
     * @return userTicket
     */
    UserTicket findByUserIdAndTicketIdAndStatus(Long userId, Long ticketId, Integer status);

    /**
     * 查询所有未使用的优惠券
     *
     * @param status 优惠券状态
     * @return list
     */
    List<UserTicket> findAllByStatus(Integer status);

}
